草庐IT

C++ 对和指针

全部标签

c++ - 如何在 std::set 中存储指向对象的指针(或引用)

在C++11STL中是否有适当的方法将对象指针存储在std::set中?,并让它们按对象的operator正确排序方法?当然,我也可以自己编写Compare输入并将其传递给set作为它的第二个模板参数,但我想STL会提供一种更方便的方法。谷歌搜索显示std::reference_wrapper,在我看来应该允许这样的代码:#include#includestructT{intval;booloperatorval>s;Ta{5};s.insert(a);}但实际上,这会导致编译错误:clang++-std=c++11-Wall-Wextra-pedantictest.cpp-otest

c++ - std::unique_ptr::reset 检查托管指针是否为空?

我一直在阅读有关C++11智能指针的内容,以便在我的源代码中使用它们,我一直在阅读的文档是cppreference.com上的文档;在阅读std::unique_ptr时,在resetfunction上有一个文档对我来说似乎不正确(强调我的):Replacesthemanagedobject.Givencurrent_ptr,thepointerthatwasmanagedby*this,performsthefollowingactions,inthisorder:Savesacopyofthecurrentpointerold_ptr=current_ptr.Overwritest

c++ - 如何避免指针运算中的乘法?

如果我写intmain(intargc,char*argv[]){inttemp[50][3];return&temp[argc]-&temp[0];}然后用VisualC++编译,我回来了:009360D055pushebp009360D18BECmovebp,esp009360D38B4508moveax,dwordptr[argc]009360D68D0C40leaecx,[eax+eax*2]009360D9B8ABAAAA2Amoveax,2AAAAAABh009360DEC1E102shlecx,2009360E1F7E9imulecx009360E3D1FAsaredx,

c++ - 将 char 指针分配给数组

voidfun(chararr[]){cout为什么我允许传递一个char指针并在数组中接收它,但不能直接将char指针分配给数组。据我所知,当我们将参数传递给函数时,赋值是隐式发生的。那么为什么会有这种差异在行为上? 最佳答案 声明voidfun(chararr[]){相当于voidfun(char*arr){这意味着,在这种情况下,不需要将字符数组的大小传递给函数。现在arr指向与ptr相同的位置。但是如果是chararr2[]=ptr;编译器不知道ptr的大小,因为它是指向字符串文字hello的第一个字符的指针,因此编译器无法

c++ - std::shared_ptr<T>:指向 T 的右值指针的隐式构造函数

我非常支持制作std::shared_ptr的想法接受T*的构造函数明确的。当您正在寻找堆损坏的原因时,它有助于避免不眠之夜。ScottMeyers对此给出了很好的解释。但是……如果我给它一个rvalue这不是明确的指针吗?我可以做这样的事情:///(1)std::shared_ptrt=newT;或///(2)T*giveaway=newT;std::shared_ptrt=std::move(giveaway);或者现实生活中更痛苦的案例///(3)voidfoo(std::shared_ptrt);///...foo(newT);对于我来说,所有这些案例都足够明确了。案例(1)是

c++ - 优化器删除指针取消引用行

我遇到一个问题,优化器似乎删除了非常必要的代码行。一些背景:我有一个连接PCIe驱动程序的程序。我有一个整数指针UINT32*bar_reg;指向我正在通信的BAR寄存器的用户空间地址。要写入寄存器,我只是取消引用指针。*(bar_reg+OFFSET)=value;没有优化,这工作正常。但是,一旦我打开任何级别的优化,所有取消引用指针的行都会被删除。我最终发现这一点的方法是在VisualStudio中单步执行。但是它独立于平台发生。到目前为止,我已经能够在关闭优化器的情况下过关,但是有人在Linux中使用我的库代码现在想打开优化器。所以我很好奇为什么会出现这个问题以及最合理的修复/解

c++ - 使用 shared_ptr 的内部指针的操作是原子的吗?

同时复制和重置shared_ptr是否安全?即考虑下面的代码//Mainthread(beforecreatinganyotherthreads)shared_ptra(newA(1));//Thread1shared_ptra_copy=a;//Thread2a.reset(new(A(2));其中线程1和2并行运行。我可以确定a_copy将存储指向较旧的A(1)或较新的A(2)共享对象的指针吗? 最佳答案 来自cppreference:Allmemberfunctions(includingcopyconstructorandc

c++ - 为什么可以将一个数组赋值给一个char指针?

通常当您声明一个指针(例如int)时,您必须为其分配一个内存地址:intvalue=123;int*p=&value;当您创建一个字符指针时,您可以为其分配一个字符数组而不需要包含地址:char*c="CharArray";这是如何运作的?它是否分配内存并指向它?为什么其他类型的指针不能做同样的事情? 最佳答案 Howdoesthiswork?字符串文字存储在可执行文件的只读数据部分(意味着它在编译期间初始化)并且c被初始化为指向该内存位置。隐式array-to-pointerconversion处理其余部分。请注意,将字符串文字转

C++ this怎么不是成员函数指针?

根据以下测试:std::cout::value不是成员函数指针,而是普通函数,而这个:std::cout::value计算结果为真。我用gcc和msvc都试过了。这两个声明有什么区别?这些结果正确吗?为什么A::*周围的括号很重要? 最佳答案 intA::*()是函数类型,它返回A的int成员,不带任何参数。所以它不是成员函数指针,更不是函数指针。std::cout::value::value::value括号改变了优先级,int(A::*)()是A的成员函数指针类型,返回int并且不带任何参数。

c++ - 使用 std::move 与使用指向线程的指针相比是否有性能成本?

我想std::move()在类似这样的情况下会有更多的性能成本:std::threadthrd(&func,this);someArrOfThreads[0]=std::move(thrd);对比std::thread*thrd=newstd::thread(&func,this);someArrOfThreadPointers[0]=thrd;这是真的吗?如果是这样,是std::move()改变了线程的内存边界还是其他原因?我意识到区别在于,第一个我实际上是将数组的值分配给线程,另一个是指向线程的指针,第二个线程保留在它的地址中。 最佳答案